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(57) Abstract: A method for processing digital video data intended for normal mode display to obtain corresponding digital video 
data for trick-mode display includes modifying the normal mode digital video data to achieve a substantially uniform delivery rate to 
a video client. This results in smoother trick-mode playback. The modified normal mode digital video data is saved as a trick-mode 
file. When trick-mode playback is requested, a video-server retrieves data from the trick-mode file. 
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5 TRICK-MODE PROCESSING FOR DIGITAL VIDEO 

This application relates to processing digital video, and in particular, to the 
display of digital video files in fast-forward or rewind mode. 

BACKGROUND 

When viewing a film, it is often desirable to skip over uninteresting scenes or, 
1 0 conversely, to rewind the film to repeat certain scenes. As a result, virtually all video 

playback units include fast-forward and rewind controls that enable the viewer to rapidly 
move forward or backward along the film. 

However, without the ability to identify selected portions of the film, it is difficult 
for a viewer to determine how long to operate in fast-forward or rewind mode. To address 
1 5 this difficulty, virtually all video playback units provide some position-indicating 

feedback to the viewer. A particularly useful method of providing such feedback is to 
continue displaying the film when operating in fast-forward or rewind. These two types 
of displays are collectively referred to in the industry as "trick-mode" displays. 

In both analog and digital video delivery systems, an ordered sequence of images 
20 is shown to the viewer at a rate (approximately 24 images per second) that is fast enough 
to give the user the illusion of motion. Aside from the improved image and sound quality 
associated with digital video, there is little noticeable difference between these delivery 
systems so long as they operate in normal mode. The difference between analog and 
digital video delivery systems becomes quite apparent, however, when one switches to 
25 trick-mode display. 

When operating in trick-mode, an analog video delivery system, such as a video 
tape recorder, simply speeds up the rate at which the medium containing the video signal 
slides past a read head. To a first approximation, this results in a uniform compression of 
the temporal axis. A viewer thus sees all the action in the film being performed at a 
30 uniformly accelerated pace. 

In contrast, a digital video delivery system operating in trick-mode generally does 
not show each image from the sequence of images making up the film. Instead, a trick- 
mode processor selects a subset of images firom the film and transmits those images to a 
decoder for display to the viewer. Since these selected images are generally represented 
35 by differing amounts of data, they take varying amounts of time to reach the decoder and 
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5 varying amounts of time to be processed by the decoder. The sum of the transmission 
time and the processing time is referred to as the "delivery interval." 

When the decoder receives a first selected image, it decodes it and provides the 
resulting signal to the video input of a television for display to the viewer. The decoder 
repeatedly provides this signal to the video input until a second selected image becomes 
1 0 available for display. The viewer thus sees the first selected image while the decoder 

processes the second selected image. When the decoder completes processing the second 
selected image, it provides this new signal to the video input. The viewer then sees the 
second selected image. 

The length of the time interval during which the viewer sees the first selected 
1 5 image thus depends on the time required to have the second selected image ready for 
display. Since the selected images can have very different sizes, this time interval can 
vary significantly. For example, if the second image is represented using only a very 
small amount of data, only a short time elapses before it is ready for display. 
Consequently, the viewer will see the first image for only a very short time before it is 
20 replaced by the second image. Conversely, if the second image requires considerable data 
for representation, a long time elapses before it is ready for display. Consequently, the 
viewer will see the first image for an extended period before it is finally replaced by the 
second image. 

A digital video delivery system opwating in trick-mode thus displays selected 
25 images for varying amounts of time. As a result, a viewer who activates trick-mode for a 
fixed number of seconds will advance or rewind the film by unpredictable amounts of 
time. This makes it difficult to judge, by watching the sequence of images go by, how 
much time has elapsed in the film. In addition, the subjective experience of watching a 
sequence of images in which each image is displayed for a seemingly random time can be 
30 unpleasant. 

SUMMARY 

The invention provides for the display of a video file in trick-mode by equalizing 
delivery intervals for the frames that are to be displayed. With the delivery intervals 
being substantially equal, images to be displayed in trick-mode are provided to a display 
35 device at a substantially uniform rate. This enables the display device to display each 
frame for substantially the same amount of time, thereby providing a smoother trick- 
mode display. 



2 



wo 02/35832 



PCT/USOl/31969 



5 Generally, a digital video file includes an ordered sequence of frames to be 

displayed to a viewer. In one practice of the invention, digital video data for trick-mode 
display is derived from this sequence of frames by specifying an acceptable range of 
delivery intervals and generating a modified frame for trick-mode display of the selected 
frame. The modified frame includes data representative of the selected image, but 

1 0 modified for delivery at a delivery interval within the acceptable range of delivery 
intervals. 

One method for facilitating the delivery of frames at a uniform rate is to specify a 
range of frame sizes on the basis of the acceptable range of delivery intervals and 
processing the data representative of the selected image to create a modified frame 

1 5 having a modified-frame size within the range of frame sizes. Depending on the amount 
of data representative of the selected image, this can include padding the data 
representative of the image to enable the modified-frame size to reach the lower limit of 
the specified range of frame sizes. Or, if there is too much data, this can include 
degrading the image by selectively reducing the amount of data representative of the 

20 image so that the modified-frame size falls below the upper limit of the specified range. 

One way to selectively reduce the amount of data representative of the image is to 
discard selected high frequency coefficients from that data. This can be achieved directly 
by simply deleting those coefficients. However, this can also be achieved by changing a 
quantizer scale associated with the data representative of the selected image. 

25 The image can be degraded uniformly, so that all portions of the image are 

degraded in the same way. Or, the degradation of the image can be selective, so that 
different portions of the image are degraded by different amounts. In the latter case, the 
image can be divided into zones, with each zone being weighted by a relative importance. 
The degradation for portions of the image that fall within a zone can then depend on the 

30 relative importance of that zone to the user's perception. In many cases, the zone of most 
importance is the central portion of an image. In such cases, it is preferable to degrade the 
peripheral portion of the image more than the central portion of the image. 

The digital video data can be encoded in any manner. The method of the 
invention can be adapted to the trick-mode display of MPEG files, wavelet encoded files, 
35 and other files containing compressed video data. 
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5 When the digital video file is an MPEG file, the ordered sequence of frames can 

be a sequence of intra-coded frames. The sequence of modified frames can then be saved 
in a trick-file containing modified intra-coded frames. In one practice of the invention, 
these modified intra-coded frames are separated by frames specifying zero motion. 

Where the selected frame contains interlaced video data, the method optionally 
10 includes removal of the interlacing so as to provide a more flicker-free display in trick- 
mode. In the case of an MPEG file, in which a frame includes two fields, this can include 
overwriting one field with the contents of the other. 

To facilitate transitions between normal and trick-mode display of data, the 
method of the invention includes indexing the modified frame to the selected frame. This 
15 facilitates fransifion between a normal mode display, in which data representative of the 
image is obtained from the selected frame, and a trick-mode in which data representative 
of the image is obtained from the modified frame. 

The invention also provides for two different video data sources: a first source for 
trick-mode display and a second source for normal mode display. In response to an 
20 instruction to transition from normal mode display of digital video data to trick-mode 
display, the method of the invention includes serving frick-mode data from the first 
source. In response to an instruction to transition from trick-mode display to normal 
mode display, the method includes serving normal mode data from the second source. 

These and other features of the invention will be apparent from the following 
25 detailed description and the drawings, in which: 

BRIEF DESCRIPTION OF THE FIGURES 

FIG. 1 shows a video delivery system for practice of the invention; 

FIG. 2 is a more detailed diagram of the video client shown in FIG. 1; 

FIG. 3 is a schematic diagram of a disk-head reading a file on the mass-storage 
30 subsystem of FIG. 1 ; 

FIG. 4 illustrates the process of creating a trick-file corresponding to the content 
file shown in FIG. 1; and 
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5 FIG. 5 is a flowchart of the majaner in which video data from the content file of 

FIG. 1 is modified to achieve a substantially uniform delivery rate in trick- 
mode. 

DETAILED DESCRIPTION 

FIG. 1 shows a video delivery system 10 that includes a video server 12 in 
1 0 communication with both a mass-storage subsystem 14 and a high bandwidth data- 
communication network 16. The video server 12 is in communication with a large 
number of subscribing video clients through the data communication network 16. For 
simplicity, FIG. 1 illustrates a representative connection to one such video client 18. 

Although shown schematically as a single disk, the mass-storage subsystem 14 is 
1 5 more typically an array of disks under the control of a RAID controller. However, the 
mass-storage subsystem 14 can be an optical disk, for example a DVD, or magnetic tape, 
or any other medium for data storage. The mass-storage subsystem 14 holds data 
representative of video content to be delivered to the video client 18 for real-time 
viewing. This video content is typically stored as a content file 20. Each content file 20 
20 consists of a sequence of frames, each carrying data representative of an image. The 
content file 20 is typically an MPEG file, the structure of which is well-known and 
described in such publications as ITU-T Recommendation H.262, the contents of which 
are incorporated by this reference. 

The video client 18, shown in more detail in FIG. 2, includes a buffer 22 for 
25 temporary storage of one or more frames received from the video server 1 2 over a 

network interface 24. The buffer 22 is in communication with a decoder 26 that retrieves 
frames from the buffer 22 and recovers the data encoded into those frames. This 
recovered data is then provided to a display driver 28 for translation into a form suitable 
for delivery to a display device 30. A processor 32 controls the operation of the video 
30 client 18 in response to instructions received from a viewer 36 through a viewer-interface 
38. 

Using the viewer- interface 38, the viewer 36 issues instructions to perform such 
tasks as selecting the content to be played and initiating the play of that content in normal 
mode. Among the instructions that the viewer 36 can issue is an instruction to play the 
35 content in fast-forward or fast-backward mode. These two modes are collectively referred 
to as "trick-mode." 
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5 In normal mode, the video server 12 retrieves frames from the MPEG content file 

20 and transmits them to the video cHent 18. As shown in FIG. 3, these frames include 
'T' (intra-coded) frames separated from each other by approximately half a second of 
normal playback time. Each I-frame is thus a self-contained representation of an image. 

The half-second of normal playback time between I-frames is filled with "P" 
10 (predictive) frames and "B" (bidirectional) frames. A P-frame encodes differences 
between its corresponding image and the image corresponding to a previous I- or P- 
frame, A B-frame encodes differences between its corresponding image and the image(s) 
corresponding to a previous and/or subsequent I- or P-frame. Consequently, unlike an I- 
frame, neither the P-frame nor the B-frame can be used in isolation to construct an image, 

15 In a trick-mode display, only selected frames are displayed to the viewer. Because 

they can be decoded independently of any other frames, the frames selected for trick- 
mode display are typically I-frames. In a conventional trick-mode display, these frames 
are read directly from the content file 20 and provided to the decoder 26. 

As noted above, a disadvantage of the conventional trick-mode display is that the 
20 I-frames contain differing amounts of data and therefore require different delivery 

intervals before being available for display. An additional disadvantage is that whenever 
a disk-head 40 reads data, it reads a fixed amount of data. As suggested by FIG. 3, this 
fixed amount of data may encompass not only an I-frame but portions of neighboring P- 
jframes or B-firames. In normal mode, these portions of neighboring frames are eventually 
25 used because all frames are ultimately displayed. However, in trick-mode, these portions 
are discarded. Hence, the bandwidth required to retrieve and transmit them is wasted. 

A system incorporating the invention includes separate trick-files 42a, 42b stored 
on the mass-storage subsystem. A forward trick-file 42a is used for fast-forward trick- 
mode display and a backward trick-file 42b is used for fast-backward trick-mode display. 

30 These trick-files 42a, 42b includes "T" (trick) fi:ames that correspond to the I-frames in 
the content file 20. When operating in trick-mode, the video server 12 retrieves T-fi-ames 
from the appropriate trick-file 42a, 42b rather than I-frames from the content file 20. 
Because each T-frame is potentially displayed to the viewer, the fact that the disk-head 
40 may read portions of neighboring T-fi-ames no longer represents a waste of bandwidth 

35 when operating in trick-mode. 
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5 While the illustrated embodiment specifies that frames selected for display in 

trick-mode be I-frames, it is possible to include P-frames or B-frames within the set of 
selected frames. Doing so provides smoother trick-mode display than can be achieved 
with I-frames alone, but at the cost of additional processing complexity. 

Referring now to FIG. 4, the trick-files 42z, 42b are created in advance by 
1 0 extracting the I-frames from an MPEG content file 20 to create an I-frame sequence 44. 
Each I-frame from the I-frame sequence 44 is then provided to a trick-file process 46. 
The trick-file process 46 modifies the data contained within the I-frame to ensure that the 
delivery interval for that data conforms to a range of specified delivery intervals. It does 
so by taking into account the number of frames per second ("FPS") that the display 
1 5 device expects, the transport bit rate ("TBR") for the network, and the video bit rate 
("VBR"). 

The modified data generated by the trick-file process 46 is then used as a basis for 
constructing a T-frame. To enable it to be decoded transparently by any decoder, a T- 
firame is encoded in the same manner as an I-frame. It is referred to as a T-frame only to 
20 avoid confiision with the I-frame that is input to the trick-file process 46 to create it. 

The T-frames generated by the trick-file process 46 are then interleaved with B- 
frames or P-franes specifying zero motion vectors. This causes the decoder 26 to simply 
repeat the preceding T-frame, The T-frames, together with the B-frames or P-frames 
interieaved between them, form a T-frame sequence 48. This T-frame sequence is written 

25 to the mass-storage subsystem as the forward trick-file 42a. A copy of the T-frame 

sequence 48 is then provided to an inverter 50 that rearranges the time-stamps associated 
with the T-frames to create the backward trick-file 42b. Both trick-files 42a, 42b have the 
same transport and video bit rates, the same picture resolution, and the same number of 
frames per second as the content file 20 from which they were derived. However, the 

30 time-stamps for the backward trick-file 42b will run in the opposite direction from those 
in the forward trick-file 42a. 

The trick-file process 46 also creates an index file 52 that correlates T-frames in 
the trick-files 42a, 42b with their corresponding I-frames in the content file 20. The index 
file 52 enables the video server 12 to know which frame to retrieve from the appropriate 
35 trick-mode file 42a, 42b when the viewer 36 issues an instruction to display in trick- 
mode and which frame to retrieve from the content file 20 when the viewer 36 issues an 
instruction to revert to normal mode. 
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5 FIG. 5 illustrates the method used by the trick-file process 46 to modify I-frames 

to generate corresponding T-frames. The method begins with the evaluation 52 of the 
allowable range of sizes for the resulting T-frames. This allowable range of sizes is 
calculated from the allowable range of delivery intervals on the basis of the number of 
frames per second that the diqslay device expects, the transport bit rate for the network, 

1 0 and the video bit rate. The trick-file process then rehieves 54 an I-frame from the content 
file and removes 56 any extraneous null padding or user data that is encoded in that I- 
frame. 

Where the content file encoded as interlaced rather than as progressive scan, the I- 
frame consists of two fields to be displayed 1/60 second apart (in the case of display 
1 5 devices operating at 30 fps). To avoid an unpleasant flickering effect when the display 
device repeatedly switches back and forth between the two fields, the method includes 
the optional step of overwriting 58 the contents of one field with the contents of the other 
field. This step is unnecessary when the content file is encoded as progressive scan. 

The trick-file process then determines 60 whether the amount of data in the 1- 
20 frame is such that the delivery interval for that I-frame is within the allowable range. If 
the amount of data is such that this is the case, then the I-frame is added 62 to the trick- 
file sequence, a B-frame (or a P-frame) is added 64 after the I-frame (now referred to as a 
T-frame), and an entry is made 66 in the index file. The trick-file process then determines 
if there are any additional I-frames to process 68. If there are no additional I-frames to 
25 process, the trick-file process writes 69 the trick-file to the mass-storage subsystem. 

In an optional practice of the invention, the trick-file is written incrementally, 
with additional T-frames being added to the trick-file as they are generated. The practice 
of incrementally writing the trick-file enables the implementation of trick-mode display 
of live-broadcasts. 

30 If the I-frame contains too little data 70, the delivery interval for that I-frame will 

be too short. Under these circumstances, the trick-file process creates a corresponding T- 
frame by adding null padding to the I-frame 72. The trick-file process then checks the 
size of the padded frame 60 and, if the size is within the allowed range, proceeds to add 
62 that frame to the trick-file sequence and to carry out the subsequent steps as described 

35 above. Alternatively, null transport packets are added to the trick-file to consume 

additional space and to thereby postpone the time at which the excessively short I-frame 
will be available for display. 
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5 If the I-frame contains too much data, the delivery interval for that I-frame will be 

too long. Under these circumstances, the trick-file process creates a corresponding T- 
frame by selectively removing data from the I-fiame 74. 

An image encoded into an MPEG file is divided into a large number of 
macroblocks, each of which corresponds to a portion of the image. Each macroblock is 

10 then subjected to a discrete cosine transform (DCT), the result of which is a table of DCT 
coefficients representative of the amplitudes of the various spatial frequency components 
that make up that portion of the image represented by the macroblock. To achieve further 
compression, these amplitudes can be scaled down, thereby enabling them to be 
represented by a smaller number of bits. This is achieved in a quantization step in which 

1 5 each DCT coefficient in a macroblock is divided by a corresponding entry from a 

quantization table. This step is referred to as "quantization" because, as a result of round- 
off and truncation inherent in integer division, a DCT coefficient may not be recoverable 
in its original pre-quantization form. As a result, this step introduces a quantization error. 
By adjusting this quantization error, the trick-file process can adjust the size of the fi-ame. 

20 In one practice of the invention, the trick-file process scales the entries in the 

quantization table used in originally encoding the "I" frame. The DCT coefficients are 
then re-quantized using the scaled quantizafion table and the resulting re-quantized DCT 
coefficients are used to encode the "T" frame. The quantization table is scaled such that 
the re-quantized DCT coefficients are representable with fewer bits than the originally 

25 quantized DCT coefficients. This enables the resulting T-frame to include less data and to 
therefore have a shorter delivery interval. 

The foregoing re-quantization results in additional image degradation. To 
minimize the perception of image degradation, different quantization tables can be used 
for different portions of the image. For example, since the central zone of the image is 
30 often where a viewer's attention is focused, the quantization tables for macroblocks fi:om 
the central zone can be altered only slightly or not at all. Macroblocks from the periphery 
of the image could then be altered to degrade those portions of the image far more than 
would be tolerable in the central zone of the image. 

Stated more generally, an image can be divided into two or more zones, each of 
35 which has a weight indicative of the attention that image is likely to receive from a 
viewer. The quanfization table to be used for requantizing a macroblock can then be 
made a fiinction of what zone that macroblock lies within. In the above example, there 
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5 are two zones, with the more perceptually important zone being the center of the image. 
However, the perceptually important zone can be anywhere in the image. 

In practice, there may exist I-frames for which the re-quantization process 
described above reduces the amount of data so much that the resulting T-frame is too 
small. Alternatively, the re-quantization process may not succeed in reducing the amount 
10 of data sufficiently. The frame degradation step 74 is thus followed by re-execution of the 
loop that begins with the step of determining 60 whether the frame size is within a target 
range. 

The foregoing description discloses an implementation in the context of an 
MPEG-2 file. However, the method is clearly applicable to digital video that is encoded 
15 in other MPEG formats (such as MPEG-4) and using other compression methods. For 
example, digital video compressed using wavelet transforms rather than discrete cosine 
transforms also can be displayed in trick-mode using the method described herein. 

Having described the invention, and a preferred embodiment thereof, what is 
claimed as new and secured by letters patent is: 



10 



wo 02/35832 



PCTAJSOl/31969 



5 CLAIMS 

1. A method for processing digital video data for trick-mode display, said digital 
video data having an ordered sequence of frames, said method comprising: 

specifying a range of delivery intervals; 

selecting a frame from said ordered sequence of frames, said selected 
1 0 frame including data representative of a selected image; 

generating a modified frame for trick-mode display of said selected 
frame, said modified frame inGluding data renresjentative of said 
selected image and being modified for delivery at a delivery interval 
within said range of delivery intervals. 

15 2. The method of claim 1 further comprising including said modified fiBme in a 
sequence of modified frames to be displayed in trick-mode. 

3. The method of claim 1 wherein generating a modified frame comprises 

specifying a range of frame sizes on the basis of said specified range of 
delivery intervals; and 

20 processing said data representative of said selected image to create a 

modified frame having a modified-frame size within said range of 
frame sizes. 

4. The method of claim 3 wherein processing said data representative of said 
selected image comprises padding said data to enable said modified-frame size to 

25 be within said specified range of frame sizes. 

5 The method of claim 4 wherein padding said data comprises adding null packets 
to said data. 

6. The method of claim 3 wherein processing said data representative of said 
selected image comprises degrading said data representative of said selected 
30 image such that said modified frame size is less than an upper bound of said range 

of frame sizes. 
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5 7. The method of claim 6 wherein degrading comprises discarding selected high 
frequency coefficients from said data representative of said selected image. 

8. The method of claim 6 wherein degrading comprises changing a quantizer scale 
associated with said data representative of said selected image. 

9. The method of claim 6 wherein degrading comprises 

1 0 selecting a first portion of said selected image; 



selecting a second portion of said selected image; 

degrading data representative of said first portion differently from data 
representative of said second portion. 

1 0* The method of claim 9 further comprising selecting said second portion to be a 



1 5 central portion of said selected frame and selecting said first portion to be a 

peripheral portion of said selected frame. 

1 1. The method of claim 2 further comprising saving said sequence of modified 
fi:ames in a trick-file. 

12. The method of claim 2 fiirther comprising transmitting said sequence of modified 
20 frames to a video client. 

13. The method of claim 11 wherein saving said sequence comprises saving 
said trick-file in a mass-storage subsystem. 

14. The method of claim 13 wherein further comprising selecting said mass-storage 
subsystem firom a group consisting of: a magnetic disk, an optical disk, and a 

25 magnetic tape. 

15. The method of claim 11 wherein said digital video file is an MPEG file and 
saving said sequence of modified frames in a trick-file comprises interieaving said 
modified frames with frames specifying zero motion. 

16. The method of claim 1 further comprising selecting said digital video file to be an 
30 MPEG file. 
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5 17. The method of claim 1 6 further comprising selecting said ordered sequence of 
frames to be a sequence of intra-coded frames. 

18. The method of claim 1 further comprising selecting said digital video file include 
an image encoded by a wavelet transform. 

19. The method of claim 1 wherein said selected frame includes interlaced video data 
1 0 and said method further comprises removing said interlaced data. 

20. The method of claim 19 wherein removing said interlaced video data from said 
frame comprises overwriting a second field of said frame with a first field of said 
frame. 

21. The method of claim 1 further comprising indexing said modified frame to said 

1 5 selected frame thereby enabling transition between a normal mode, in which data 

representative of said image is obtained from said selected frame, and a trick- 
mode in which data representative of said image is obtained from said modified 
frame. 

22. A method for processing digital video data for trick-mode display, said method 
20 comprising: 

obtaining, from said digital video data, first data representative of an 
image; 

generating, on the basis of said first data, second data for trick-mode 
display of said image, said second data being modified for delivery at 
25 a delivery interval within a specified range of delivery intervals. 

23. The method of claim 22 further comprising writing a trick-mode file to a mass- 
storage subsystem, said trick-mode file including said second data. 

24. The method of claim 22 wherein generating said second data comprises adjusting 
an amount of said first data such that said amount falls within a selected range of 

30 amounts, said specified range of amounts being selected on tlie basis of said 

specified range of delivery intervals. 

25. A method for transitioning between display of digital video data in normal mode 
and display of digital vide data in trick-mode, said method comprising: 
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5 detecting an instruction to transition from normal mode display of digital 

video data to trick-mode display; 

in response to said instruction, serving trick-mode data corresponding to 
said digital video data. 

26. The method of claim 25 further comprising: 

1 0 detecting an instruction to transition from trick-mode display of said 

digital video data to normal mode display of said digital video data; 
and 

in response to said instruction, serving normal mode data corresponding 
to said digital video data. 

1 5 27. The method of claim 25 wherein serving trick-mode data comprises retrieving 
said trick-mode data from a trick-mode file. 

28. The method of claim 26 wherein serving normal mode data comprises retrieving 
said normal mode data from a normal mode file. 

29. A system for serving digital video data, the system comprising: 

20 a video server for delivery of video content; and 

a mass-storage subsystem in communication with the video server, said 
mass storage subsystem including a first data set for serving said video 
content in normal mode and a second data set for serving said video 
content in trick-mode. 

25 30. The system of claim 29 further comprising an index file for correlating said first 
data set with said second data set, thereby enabling said video server to locate 
data on said second data set that coiresponds to selected data from said first data 
set. 

3 J . A computer readable medium having encoded thereon software instructions for 
30 processing digital video data for trick-mode display, said software comprising 

instructions for: 
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obtaining, from said digital video data, first data representative of an 
image; 

generating, on the basis of said first data, second data for trick-mode 
display of said image, said second data being modified for delivery at 
a delivery interval within a specified range of delivery intervals. 
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